UPDATE

更新时间:

云原生数据仓库 AnalyticDB MySQL 版支持使用UPDATE语法更新单表数据或多表关联数据。

注意事项

  • 执行UPDATE命令时,要求表中存在主键。

  • 暂不支持更新主键列。

  • 仅单表更新支持ORDER BYLIMIT子句。

  • 在更新数据量较大或数据更新频率高(超过100 QPS)的场景下,使用UPDATE更新数据会导致CPU使用率升高。建议您使用REPLACE INTO批量更新数据。详情请参见REPLACE INTO

单表更新

语法

UPDATE table_name
    SET assignment_list
    [WHERE where_condition]
    [ORDER BY ...] 
    [LIMIT ...]  

示例

customer表中customer_id ='2369'顾客的姓名更改为黄先生。

UPDATE 
      customer 
SET 
      customer_name ='黄先生' 
WHERE 
      customer_id ='2369';      

多表更新

版本要求

3.1.6.4及以上内核版本的集群支持多表更新。

说明
  • 查看企业版基础版湖仓版集群的内核版本,请执行SELECT adb_version();。如需升级内核版本,请联系技术支持。

  • 查看和升级数仓版集群的内核版本,请参见查看和升级版本

语法

UPDATE Table_name1
[INNER JOIN | LEFT JOIN] Table_name2 ON Table_name1.C1 = Table_name2.C1
SET assignment_list
[WHERE where_condition]

注意事项

  • 多表更新仅支持同时更新两张表。

  • 多表更新不支持ORDER BYLIMIT子句。

  • 多表更新时,一条SQL语句只能更新一张表,不支持同时更新多张表。

  • 多表更新时,表顺序敏感,需要将待更新的表写在首位。例如,将customer表中的customer_id更新为1,语句如下:

    UPDATE customer LEFT JOIN new_customer ON customer.customer_name = new_customer.customer_name SET customer.customer_id = '1';

示例

  • LEFT JOIN子句与UPDATE语句一起使用。

    customer_id ='2369'顾客的年龄更新为42。

    UPDATE customer
        LEFT JOIN new_customer ON customer.customer_id = new_customer.customer_id
    SET
        customer.customer_age = 42
    WHERE
        new_customer.customer_id = '2369';
  • INNER JOIN子句与UPDATE语句一起使用。

    customer表中的customer_id更新为2369。

    UPDATE customer
        INNER JOIN new_customer ON customer.customer_name = new_customer.customer_name 
    SET 
        customer.customer_id = '2369';

    customer表中的customer_name更新为new_customer表中的customer_name。

    UPDATE customer
        INNER JOIN new_customer ON customer.customer_id = new_customer.customer_id
    SET
        customer.customer_name = new_customer.customer_name;